// axios 的封装处理
import axios from 'axios'
import { getToken, removeToken } from './token'
import router from '@/router'
import { message } from 'antd'

// 1. 根域名配置
// 2. 超时时间
// 3. 请求拦截器 / 响应拦截器

const request = axios.create({
  baseURL: 'http://geek.itheima.net/v1_0',
  timeout: 5000,
})

// 添加请求拦截器
// 在请求发送之前 做拦截 插入一些自定义的配置 [参数的处理]
request.interceptors.request.use(
  (config) => {
    // 操作这个 config 注入 token 数据
    // 1. 获取到 token
    // 2. 按照后端的格式要求做 token 拼接
    const token = getToken()
    if (token) {
      config.headers.Authorization = `Bearer ${token}`
    }
    return config
  },
  (error) => {
    return Promise.reject(error)
  }
)

// 添加响应拦截器
// 在响应返回到客户端之前 做拦截 重点处理返回的数据
request.interceptors.response.use(
  (response) => {
    // 2xx 范围内的状态码都会触发该函数
    // 对响应数据做点什么
    return response.data
  },
  (error) => {
    // 超出 2xx 范围的状态码都会触发该函数
    // 对响应错误做点什么
    // 监控 401 token 失效
    if (error.code === 'ECONNABORTED') {
      message.error('请求超时，请稍后重试')
      return Promise.reject(error)
    }

    if (error.response?.status === 401) {
      removeToken()
      router.navigate('/login')
    }

    if (!error.response?.data) {
      message.error('网络错误，请稍后重试')
    } else {
      message.error(error.response?.data?.message)
    }
    return Promise.reject(error)
  }
)

export default request
